package Lee_code;

/**
 * @author blh
 * @date 2024年07月09日 7:45
 */
public class Lee_518_79 {
    public int change(int amount, int[] coins) {
        int len = coins.length;
        // amount是背包, coins是物品
        // 因为是求组合数, 所以先物品后背包(无顺序)
        // 求排列数, 先背包后物品
        int[] dp = new int[amount + 1];
        dp[0] = 1;
        for (int i = 0; i < len; i++) {
            for (int j = coins[i]; j <= amount; j++) {
                dp[j] = dp[j] + dp[j - coins[i]];
            }
        }
        return dp[amount];
    }
}
